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data processing division 


LGP-30 
THE ROYAL PRECISION 
DIGITAL 
COMPUTER 


PURPOSE: 


This manual describes the operation of the LGP-30 Digital Computer. 
It is intended for the reader who has some knowledge of computer 


techniques but wishes to know just how the LGP-30 operates. 


The success of the desk-size digital computer is attributed to 

its wide range of applications. It makes it possible for small business 
operation to use automatic data processing techniques economically ; 
to operate as larger computing installations with less “waiting 
time” and consequently quicker evaluation. It can be used in 
conjunction with large scale installations or in place of large scale 


installations where the latter are not economically justified. 


When used with large scale computers, it serves to eliminate the 
bottleneck by decentralizing operation. The LGP-30 makes it possible 
to quickly evaluate trial ideas associated with more complex 
engineering designs, before putting the over-all problem on the 


larger computer. 


When used alone, it permits the smaller company to obtain realistic 
answers to problems quickly and reduces the lengthy manual 


calculations from man-weeks to a few man-hours. 


For the first time small business can justify the cost of the computer 
since it may be operated with no additional electrical service, 


ventilation, or cooling and requires a minimum of floor space. 


Copyright, 1959 by Royal McBee Corporation, Port Chester, N. Y. 
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General Characteristics 


THE LGP-380 is a desk-size, stored program computer. 
It has a medium-scale capacity and uses a single address 
system. The LGP-80 has all the advantage of high com- 
ponent reliability, automatic operation, compact design, 
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and ease of programming. Because of its great flexi- 
bility, the LGP-30 serves the needs of accounting, en- 
gineering, and scientific computing fields in a most 
efficient manner. 


Components 


The three basic components of a computer memory 
unit, arithmetic unit, and control unit are assembled in 
one desk-size housing in the LGP-30. The main memory 
of 4096 words is a magnetic drum, see figure 1, which 
rotates at 4000 revolutions per minute, thus making 
possible a maximum access time of 15 milliseconds. The 
memory is arranged on the drum on 64 tracks, each 
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FIGURE 2. Standard Keyboard of Tape Typewriter 


track containing 64 sectors. Punched paper tape is the 
permanent file of information for the LGP-30. The 
interlace pattern of sectors on each track of the drum 
makes for shorter access time. The drum will retain its 
memory when power has been turned off. 


Input-Output Device 


The primary input-output device to the LGP-30 is a 
Tape Typewriter. It has a standard typewriter key- 
board and control switches, as shown in Figure 2, and a 
paper tape reader and punch which are integral parts 
of the input-output unit. 

Input information to the LGP-30 is transmitted from 
the Tape Typewriter or from the paper tape reader on 
the typewriter. 


Output information from the LGP-30 is recorded on 
the typewriter or the typewriter and paper tape punch 
simultaneously. Maximum typewriter speed for input 
and output is 10 characters per second. Higher speed 
input and output devices are available, such as a photo- 
electric reader which reads input at 200 characters per 
second and an output device which punches 20 charac- 
ters per second. 

One of the primary considerations in designing the 
LGP-30 was to minimize the number of components, 
thus increasing its reliability and limiting its size and 
cost. The computer is internally binary. Many com- 
ponents in the LGP-30 are used on a time-sharing basis. 
Input-Output is normally decimal with the LGP-30 
doing the binary conversion during input and output 
time. 

Programs are usually punched on a tape by means of 
the Tape Typewriter and then read into the computer. 
However, the LGP-30 may be stopped at any time,. to 
enter information manually from the Tape Typewriter. 


Word Structure 


The basic unit of information is defined as a word. 
The LGP-30 word contains 30 binary bits plus a sign 
bit and spacer bit. The 30 binary bits and sign position 
may be recorded as “0” or “1” on the magnetic drum. 
The spacer bit is used to separate adjacent words. on 
the drum and is always recorded as “‘0.”’ As many as 9 
decimal digits may be represented in one data word. 

A word may be used to store data or an instruction as 
shown in Figure 3. Negative numbers are represented 
as a two’s complement. 
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FIGURE 3. Word Structure 


Addressing Systems 
THE 4096 WORDS of the LGP-30 are addressed in terms 


_of track and sector. This convention has been adopted 


to facilitate optimum programming which will be de- 
scribed later. Other addressing methods could be 
adopted and are perfectly feasible, such as addressing 
memory 0000 through 4095; however, in this manual, 
manual locations will be identified in terms of track and 
sector. Each track is addressed 00 through 63 and each 
sector is addressed 00 through 63. There is no break in 
continuity of addresses from one sector to the next or 
from one track to the next; 1723 represents the word 
whose address is track 17, sector 23. Consecutive ad- 
dresses are then labeled 0000, 0001, 0002, .. . 0063, 0100, 


0101 .... 6863. Figure 3 shows that part of the word is 
reserved for the track and sector, namely: 6 bits each. 
The homogeneous memory of the LGP-30 makes pos- 
sible random access to any one of 4096 word locations. 
When an instruction located in memory is executed, the 
result may be stored in any one of the 4096 locations 
on the drum. 

All instructions, except the P, I and Z orders, contain 
addresses which refer to the location of a word in 
memory. The commands P, I, and Z will be defined in 
the section on Operations. 


Computing Unit 


INTERNAL CALCULATION is accomplished by directing in- 
formation to the computing section from memory, 
processing it, and directing it back to memory. The 
computing section consists of three working registers: 
the counter register (C), the instruction register (R), 
and the accumulator register (A). The three registers 
are located on three separate recirculating tracks on the 
LGP-30 drum, in addition to the 64 tracks of memory. 

The accumulator, A, is the working register. It con- 
tains the results of addition, subtraction, multiplication, 
etc., as these operations occur. It also contains one of 
the operands, prior to execution of an arithmetic in- 
struction; the second operand is in memory at the word 
location specified by the address part of the instruction. 

The instruction register, R, contains the instruction 
being executed. Both the operation and the address of 
the instruction are located in this register. Words are 
transmitted from memory to this register. Generally, 
these words are instructions of a program stored in 
memory. The instruction register may be interrogated 
to determine the operation to be performed. 

The counter register, C, contains the location of the 
next instruction to be executed, i.e., if the counter 
register reads 2438, the next instruction to be executed 
is stored at 2438 or track 24, sector 38. This register 
contains only the address part of a word. The address 
part of the instruction register may be transferred to 
the counter register. The address part of the counter 
register may be transferred through a plus 1 adder to 
memory by use of the R command. During the execution 
of every operation, 1 is added to the counter register 
- automatically, so it will be ready to search for the next 
instruction, after it finishes the one being executed. 

The flow of information between the registers and 
memory is shown in Figure 4. The solid line indicates 
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FIGURE 4. Flow of Information Through Registers and Memory 


information being passed as a whole word. The dotted 
line indicates information affecting the address portion 
only. A typical instruction affects the registers as 
follows: 


1. The word, whose address is in the counter register, 
is placed in the instruction register. 


2. The word in the instruction register is then ex- 
ecuted and information flows along one of the lines 
represented in the diagram depending on the in- 
struction. During this time, the counter register 
is increased by 1. This completes an instruction 
cycle and the Computer starts to look again for the 
word whose address is now in the counter register. 


Control Panel 


THE LGP-30 control panel was designed for simplicity 
of operation. It displays, see Figure 5, the Oscilloscope 
recessed in the upper right hand corner of the panel 
and the translucent control buttons. These buttons, 
when lighted, indicate the operating status of the com- 
puter. The patterns on the Oscilloscope indicate the con- 
tents of the three working registers. 


OSCILLOSCOPE 


The scope furnishes the operator with a visual repre- 
sentation of the three registers as a means of checking 
or debugging his program. Three windows, one below 
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FIGURE 5. LGP-30 Control Panel 


the other, display in binary the Counter Register, C, 
the Instruction Register, R, and the Accumulator Regis- 
ter, A, from top to bottom, as shown in Fig. 6. 
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FIGURE 6. Oscilloscope Showing Three Registers 


The Counter Register, C, contains the address, or 
location (track and sector) of the next instruction to be 
executed. 

The Instruction Register, R, contains the last in- 
struction executed and during multiplication or division, 
holds the second operand. 

The Accumulator Register, A, contains the results of 
the execution of the last instruction. 


CONTROL BUTTONS 
Power On And Off Buttons 


The ‘Power On” and ‘Power Off” switches are the 
main power switches. 

It is good practice to be sure that the “Manual Input” 
button is depressed before depressing the “Power Off” 
switch. If it is not depressed when the computer ‘is 
turned on, the computer will remain in “Stand By” 
state. If it is not depressed when the power is turned 
off, some of memory may be erased. 


Stand By 

When the “Stand By” button is depressed, after the 
“Power On” button is depressed, a red light behind it 
lights up. This turns off the high voltage. 


Operate 


Depress this button to prepare the computer for 
operation. 


Stand By To Operate 

This is an indicator, not a button and cannot be de- 
pressed. It indicates that the Computer is in one phase 
of its warmup cycle. 


Mode Buttons 


The following buttons select one of the three modes 
of operation but do not cause the machine to operate. 


© Manual Input—(This is not the same as the Manual 
Input button on the Tape Typewriter.) Depressing 
this button connects the computer to the keyboard 
of the Tape Typewriter. All data typed on the key- 
board appears in the accumulator register. 
If the “start” button is depressed, the contents of 
the word whose address is in the counter register 
is displayed in the instruction register and the 
counter register is increased by one. The accumu- 
lator register is unchanged since no instruction is 
executed. This enables the operator to “step 
through” a section of memory and examine the 
contents of each word as it appears in the Instruc- 
tion Register. 


@ One Operation—Depressing this button prepares 


the computer for executing one instruction at a 
time and halt. Depressing the “start” button exe- 
cutes only the instruction whose address is in the 
counter register and stops the computer. The 
counter register is then increased by one, unless 
a transfer instruction, T or U is executed. In this 
case, the counter register contains the address of 
transfer instruction, the instruction register con- 
tains the instruction just executed (except for 
multiply and divide instructions). 


e Normal—Depressing this button sets the comput- 
ing mode to execute the stored program auto- 
matically. 


Operation Buttons 


The Start, Clear Counter, Fill Instruction, and Exe- 
cute Instruction buttons interlock with the Mode se- 
lection buttons. To simplify computer operation, a light 
under each button indicates when that button is 
operable; the lights are not lit when buttons are in- 
operable. For example, the execute instruction light is 
lighted only when the One Operation button is de- 
pressed, depressing this button in any other mode does 
not activate the computer. 


© Start—This button must be depressed to execute 
stored instructions. It is used with One Operation 
and Manual Input as explained previously. 

© Clear Counter—Depress this button to reset the 
counter register to zero to restart a program. This 
switch is used only in the Manual Input and One 
Operation modes. 

e Fill Instruction—Depress this button to transfer 
the contents of the accumulator to the instruction 
register after it has been typed into the accumula- 
tor from the keyboard. This button is used only in 
Manual Input and One Operation modes of opera- 
tion. 

e Execute Instruction—Depress this button to exe- 
cute the instruction in the instruction register. 
This button is used only in the One Operation mode.. 


e Stop—The “Stop” light panel will light red to in- 
dicate when computer has stopped. 

@ Compute—The “Compute” light panel will light 
green when computer is computing. 


The bottom row of buttons on the console panel 

displays: 

e Break Point Switches—The 4 breakpoint switches 
BP-32, BP-16, BP-8, and BP-4 are used with the 
track portion of the address of a stop order, Z. 
When the breakpoint switch is depressed, the com- 
puter ignores the “stop” instruction in the program 
and executes the following instruction. One depres- 
sion latches the breakpoint in the down position, 
a second depression releases the latch. Lights under 
the breakpoint buttons are lit when switch is down, 
in latched position. The Z command will be ex- 
plained later. . 


e 6-bit Input—This button, when depressed during 
Input, permits all six channel bits of each type- 
writer character to enter the accumulator—instead 
of the usual 4 channels when button is up. 


e Transfer Control—This button provides the opera- 
tor another means of manually controlling the 
machine. It is used with a Test Instruction (T) to 


determine which of two paths to follow in a pro- 
gram. One depression latches the button in down 
position (depressed), a second depression releases 
the latch. The T command will be explained later. 


Operation Codes 


THE OPERATIONS of the LGP-30 are grouped under arith- 
metic, logical, and input-output. In general, arithmetic 
operations are those that operate on a full 30-bit plus 
sign word; logical are those that affect only the address 
portion of the word. 


ARITHMETIC OPERATIONS 
Bring Bm 


Replace the contents of the accumulator 
with the contents of the memory loca- 
tion specified by the address, m. 


Add* Am 
Add the contents of m to the contents 
of the accumulator and retain the sum 
in the accumulator. 


_ Subtract* Sm 
Subtract the contents of m from the 
contents of the accumulator and retain 
the difference in the accumulator. 


Hold H m 


Store the contents of the accumulator 
in m, retaining the contents of the ac- 
cumulator in the accumulator. 


Clear Cm 
Store the contents of the accumulator 
in memory location, m, clearing the ac- 
cumulator to zero. 


Extract Em 

The Extract order or “logical product” 
is a bit by bit product of the contents 
of the accumulator by the contents of 
m. 

The extract order may also be explained 
‘in this way: if there is a “lI” in a bit 
position of the accumulator and a “1” 
in the corresponding bit position of the 
m word, the E order places a “1” in the 
corresponding position of the accumu- 


lator; otherwise it places a zero in the: 


accumulator. This order makes it pos- 
sible to ‘mask out” parts of a word, 


*If an ADD or SUBTRACT order results in a number 


which is too large for the 30-bit accumulator, overflow - 


will occur and the computer will stop. 


+In the multiply and divide orders, the contents of (m) are 
used for repetitive additions or subtractions and must be 
available many times. Since the instruction register i is not 
needed at the time of execution of these orders, it is re- 
placed by the contents of (m). The result of this may be 
seen if a multiply or divide command is executed during 
“One Operation” mode. The Instruction Register, R, will 
contain the multiplier or divisor of the respective instruc- 
tion rather than the instruction itself. 


Caution: When debugging a program. If overflow results 
during division, the counter register indicates where, in 


when two or more quantities are stored 
in one memory location. 


Dividet Dm 

Divide the number in the accumulator 
by the number in the memory location, 
m, retaining the quotient (rounded to 
30 bits) in the accumulator. The abso- 
lute value of the contents of m must.be 
greater than the absolute value of the 
contents of A or overflow will occur and 
the computer will stop. 


Multiplyz§ Mm 
Multiply the number in the accumula- 
tor by the number in memory location, 
m, retaining the most significant half 
of the product (30 binary places) in the 
accumulator. 


Multiplyt§ Nm 
Multiply the number on the accumula- 
tor by the number in memory location, 
m, retaining the least significant half 
of the product (30 binary places) in the 
accumulator. 


LOGICAL OPERATIONS 


Store 

Address Ym 
Store only the address portion of the 
word in the accumulator in memory 
location, m, leaving the rest of the word 
in m undisturbed. 


Return 
Address Rm 


Add “one” to the address held in the 
counter register, C, and record it in 
the address portion of the word in 
memory location, m. The counter regis- 
ter, C, normally contains the address of 
the next instruction to be executed. 
This command is used in setting a sub- 
routine exit. 


Uncondi- 

tional 

Transfer Um 
Transfer control to m unconditionally, 
i.e., get the next instruction from mem- 
ory location, m. 


the program, the computer has stopped. The instruction 
register will not contain the actual instruction being 
executed. 


§ When two 80-bit binary words plus sign are multiplied the 
result is a 60-bit product plus sign. In the M multiply 
product, only the sign and _the most significant 30 bits 
appear in the accumulator. In the N multiply product the 
least significant 30 bits of the product appear in the sign 
position through bit 29 of the accumulator, leaving bit 30 
generally 0. It will not be zero only when the spacer bit 
in the accumulator is not zero prior to the multiplication. 
This may occur only after an Input order. The spacer bit 
is always zero in memory. There is no corresponding alge- 
braic sign in the N multiply product; the result is s shifted 
one position to the left. 


Test Tm 


Conditional transfer. Transfer control 
to memory location m only if the num- 
ber in the accumulator is negative. 
Otherwise, the test command is ig- 
nored. 

-Tm 

Same as the test instruction with the 
addition that if the Transfer control 
button on the LGP-30 console is de- 
pressed or the accumulator is negative, 
the transfer will take place. 


Stop Zn 


The stop command can be made uncon- 
ditional or contingent on 4 break point 
switches depressed on the LGP-80 con- 
sole. This command enables the opera- 
tor to stop the program at selected 
points when desired. The n address 
does not refer to one of the 4096 loca- 
tions but instead to one of the 4 break 
point switches on the control panel. If 
n is 0000, the “stop” will be uncondi- 
tional; if n is 0800, the “stop” is ig- 
nored, when BP-8 switch is depressed. 


NOTE: The track portion of the operation refers to the 
break point switch number. If the switch is not depressed, 
the computer will stop. 

The sector portion of the address is irrelevant with respect 
to the function of the operation, except for optimizing which 
is explained later. 
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-INPUT-OUTPUT OPERATIONS 


Print 


Input 


Pn 


Print a Tape Typewriter symbol. The n 
address does not refer to one of the 
4096 addresses, instead the track por- 
tion is a code to print or punch a char- 
acter on the Tape Typewriter. The 
sector part of the address is irrelevant 
with respect to the function of the op- 
eration, but it does affect the timing 
and will be further explained in timing 
and optimizing. A further detailed dis- 
cussion of the print P order will be 
found in the Input-Output components 
section. 


In 


This command enters information from 
the Tape Typewriter into the accumu- 
lator. An Input order is always pre- 
ceded by a print order, but not neces- 
sarily immediately. The n address does 
not refer to one of the 4096 addresses 
and will normally be zero. The sector 
part of the address is irrelevant with 
respect to the function of the command, 
but it does affect the timing of the in- 
struction. The track portion of the ad- 
dress indicates the first four bits to 
enter the accumulator. If the 6-bit 
switch is depressed, all six bits enter 
the accumulator. 


FIGURE 7. Paper Tape Reader and Punch on Tape Typewriter 
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Input-Output Components 
for the LGP-30 


THE TAPE TYPEWRITER, Photoelectric Paper Tape 
Reader and high-speed Paper Tape Punch are the Input- 
Output devices for the LGP-30. All of these are con- 
trolled directly by the program stored in the computer. 


TAPE TYPEWRITER 


The Tape Typewriter is a typewriter with the Paper 
’ Tape Reader and Paper Tape Punch attached as integral 
parts of the unit, see Fig. 7. It may be operated inde- 
pendently of the Computer as a reading and punching 
device. Information is fed to the Computer via the type- 
writer keyboard or via punched tape in the Paper Tape 
Reader attached to the Tape Typewriter. 

Information passing through the Paper Tape Reader 
or Paper Tape Punch will also create a typewritten 
copy. These units may not be operated independently 
of the typewriter. 


Typewriter Controls Switches, Lights and 
Manual Controls 


The Tape Typewriter has a standard typewriter key- 
board, see Fig. 2, modified to use the LGP-30 codes 
shown in Appendix A. The keys that represent the com- 
mands are a different color from those on the rest of the 
keyboard. One extra code key, Conditional Stop, is added 
to the typewriter keyboard. 


e@ Conditional Stop Code (') 


This key is used to punch a code in paper tape. When 
this code is read, it has two functions: 


1. to stop the paper tape reader 
2. to send the “‘start signal” to the computer 


e Power On—Power Off Switch 

This switch, in the lower right hand corner of the 
Tape Typewriter, adjacent to the keyboard, turns the 
power to the typewriter “on” or “‘off.’”’ It is independent 
from the LGP-30 Computer power switch and must be 
turned on when punching tape or printing typewritten 
copy. 


e@ Connect Switch 

This switch allows start signals to pass from the 
Tape Typewriter. If the switch is in the “On” position, 
the “start” signal, originating from the Start button 
on the Tape Typewriter or from reading a conditional 
stop on the paper tape, will pass to the LGP-30. If the 
switch is “Off,” all start signals originating from the 
Tape Typewriter are blocked. 


e@ Start Compute 

The “Start Compute” lever on the Tape Typewriter, 
when depressed, sends a start signal to the LGP-30, to 
start computing. It duplicates the function of the 
“Start” switch on the computer, and duplicates the read- 
ing of the “start” function of a Conditional Stop code 
(') on tape. It also turns out the manual input light on 
the Tape Typewriter. 


e Manual Input (no connection with the Manual Input 
on Computer Console) 

The Manual Input lever on the Tape Typewriter de- 

termines whether information from the Tape Type- 


writer to the Computer is transmitted from the key- 
board or from the Paper Tape Reader. If the switch is 
down, the information is received from the keyboard. 
If the switch is up, the information is received from the 

Paper Tape Reader. 


@ Code Delete 


This lever is operative only when the ‘Punch On” 
switch is depressed. It is used to delete an error 
punched in the paper tape by punching holes in all 
channels 1 through 6 after tape has been rolled back 
to the error position. Then the correct code may be 
punched. 


e Tape Feed 


The Tape Feed lever, when depressed, feeds tape into 
the Paper Tape Punch. It punches the sprocket feed — 
holes only. It is operative only when the “Punch On” 
Switch has been depressed previously. The “Tape Feed” 
lever springs up into place, when released. This lever 
is used to obtain a leader at the beginning and a trailer 
at the end of the tape. 


@ Punch On 


The “Punch On” Switch turns the Paper Tape Punch 
“on” so that any characters being typed from the key- 
board or read from the Paper Tape Reader, will be 
reproduced on the Paper Tape. 


e Stop Read 


Depressing this lever will stop the Paper Tape Reader 
on the Tape Typewriter from reading any more char- 
acters. It also extinguishes the Manual Input light on 
the Tape Typewriter. 


e Start Read 
Depressing this lever will start the Paper Tape 


‘Reader, reading information. When a Conditional Stop 


code appears on the Paper Tape or when the Stop Read 
lever is depressed, the reading is stopped. 


© Conditional Stop {not the same as Conditional Stop 
Code (') key] 
This lever (on the upper frame of the typewriter), 
when depressed, will cause the Paper Tape Reader to 
ignore a Conditional Stop Code ('). 


@ Guides and Interlocks 


Guides and interlocks on both the Paper Tape Reader 
and the Paper Tape Punch feed the paper tape to the 
Tape Typewriter. If the tape breaks, the interlock is 
tripped and the Tape Typewriter automatically stops. 


@ Tabs and Carriage Returns 


Facilities for manually setting tabs and carriage 
returns are located on the rear of the carriage. 


Operation of the Tape Typewriter 
OUTPUT 


Output information is transmitted from the Com- 
puter to the Tape Typewriter by a “P” instruction with 
a specific binary code for the track portion of the ad- 
dress. The codes used to activate the characters on the 
Tape Typewriter are given in Table I, Appendix A. 

For example, if the instruction “P 1300” is given, 
the Tape Typewriter types the letter “R.” Track 13, in 
binary, is written 001101, the code for the letter “R.” 


To print any of the alpha-numeric characters or con- 
trols in Table I, the same technique is used. While there 
is a possibility of the LGP-30 sending 64 distinct codes 
to the Tape Typewriter, the Tape Typewriter is limited 
in its operation codes, as shown in Table I. If any of the 
remaining 13 codes are given, the Tape Typewriter will 
ignore them. 


After the print command, P, is given, the LGP-30 does 
not stop but may continue computing. 


The Tape Typewriter can accept only 10 characters 
per second. If two print commands are given in succes- 
sion, the second one will not be executed because the 
Tape Typewriter has not completed executing the first. 


Consequently, the problem of timing output on the 
LGP-30 must be considered. 


Two solutions are suggested: 


1. Expand the computing time between the two print 
orders so that one order has finished its print cycle 
before the second order is given. The minimum 
time between print instructions should be 0.1 
seconds or 544 drum revolutions. (This will be 
discussed further under Timing and Optimizing). 


2. The Tape Typewriter always sends a start signal to 
the computer after it finishes printing a character. 
Place a Stop instruction after each Print Instruc- 
tion. This stops the computer after the character 
has been printed, and prohibits computing be- 
tween print instructions. A start signal from the 
Tape Typewriter initiates computing again. 


‘Many output programs use the combination of the 
_ two suggestions executing instructions and following 
them with a stop order. However, care must be taken 
not to execute too many instructions before a stop order. 
If this occurs, the Tape Typewriter sends a “start” sig- 


nal back to the computer before the “stop” instruction is’ 


given. Then, when the computer stops there is no start 
signal transmitted to get it started again. 


INPUT 


Information is transmitted to the Computer from the 
Tape Typewriter in one of two methods, either by read- 
ing the information from punched paper tape by means 
of the reader unit, or by accepting information directly 
from the keyboard. 


1: From Punch Tape 


To transmit information from the punch tape, the 
reader on the Tape Typewriter or the keyboard is 
actuated by a Print Instruction P0000 from the 
Computer. However, when the keyboard is used 
to transmit information, the Manual Input switch 
must be depressed. A light in the “Manual Input” 
panel on the Tape Typewriter indicates transmis- 
sion of information from the Keyboard. The input 
order, 10000 follows but not necessarily immedi- 
ately, the print order, P. However, it must be given 
before the information on the tape appears under 
the reading head of the Paper Tape Reader, other- 
wise the information is lost. 


The combination of a P0000 and I0000 order stops 
the Computer and starts the Reader. Characters 
read from the tape are then filled into the accumu- 
lator register 4 bits or 6 bits at a time, depending 
on the position of the 6-bit Input switch on the 
computer console. 


‘ 


When the character is punched on paper tape the 
channels on the tape are numbered. 


GUIDE HOLES 


° 
° 
° 
° 
° 
° 
° 
° 
° 
° . 
° 
° 


The characters punched on the tape are in channels 
6, 1, 2, 8, 4, 5, from left to right, however, the 
computer enters characters into the accumulator 
in the order of 1, 2, 3, 4, 5, 6. 


If the 6-bit Input switch is not depressed, only 
channels 1 through 4 on the tape are transferred 
to positions 28 through 31 in the right hand end 
of the accumulator. If the 6-bit switch is depressed, 
all 6 channels of each character code are filled, 6 
bits at a time, into positions 26 through 31 of the 
accumulator. The accumulator is shifted 4 or 6 
positions before each character is entered. 


Since the accumulator holds 32 bits, including the 
sign and spacer bit, 8 characters are sufficient to 
fill the accumulator, 4 bits at a time. If the 9th 
character is read, the first character is lost. There- 
fore, a conditional stop code (') is necessary after 
8 characters. 


When a conditional stop code (') is read on the 
tape, a start signal is given to the computer. The 
computer then operates on the next instruction. 


2. From the K eyboard 


When information to the Computer is transmitted 
via the keyboard, a start signal is supplied to the 
computer by depressing the “Start Compute” lever 
on the Tape Typewriter, or the computer console. 


PHOTOELECTRIC READER AND 
PAPER TAPE PUNCH 


A high speed Photoelectric Reader and high speed 
Paper Tape Punch may be attached to the LGP-30 as 
auxiliary Input-Output equipment. The Photoelectric 
Reader shown in Fig. 8 is capable of reading 200 char- 
acters per second. The Paper Tape Punch operates at a 
speed of 20 characters per second. The combination of 
Reader and Punch as a unit is identified as Model No. 
342, the Reader alone is Model No. 341. Using the Photo- 
electric Reader and the Paper Tape Punch, there is no 
typewritten copy as a by-product of the Input or Output. 


-Manual Controls 


When switches are operated, a light behind them 
lights up, see Fig. 8. 


@ Reader Power Switch 


This switch on the console of the Photoelectric Reader 
turns the power on. The power required to operate the 


ROYAL PRECISION 


FIGURE 8. Photo-Electric Reader Model 342 


Photoelectric Reader is not available until the LGP-30 
power is turned on. The power for the Photoelectric 
Reader should not be turned on until the LGP-30 is in 
operate status. 


e@ Reader Stop 


This button is used to stop the transport of paper 
tape through the Photoelectric Reader. There is no 
manual “start read” switch on the Photoelectric Reader. 


e Punch Power 


This switch turns the p»wer on in the Paper Tape 
Punch. The Punch may be operated without the reader 
power switch on. This switch should not be turned on 
until the LGP-30 is in operate status. 


e Tape Feed Switch 


This switch feeds the tape to the punch unit. Only the 
sprocket holes are punched. 


@ Input 


This switch selects the Tape Typewriter or the Photo- 
electric Reader as the Input device for the LGP-30. 
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©@ Output 


This switch selects the Tape Typewriter or the Photo- 
electric Reader as the Output device for the LGP-30. 


Operation of Photoelectric Reader 
To operate reader: 


1. Turn Computer on and make ready to operate by 
warming up. 

2. Depress Reader Power switch. 

3. Place tape face down in Reader starting with 6 in. 
leader. 

4. Locate tape inside guide pins under reader head 
and snap clamps on tape. 

5. Set Input switch to Reader. 

The Computer is now ready to accept information 

from the Photoelectric Reader. 


Operation of Computer and Reader 


A P0000 instruction is ignored by the Reader, when 
the Computer is connected, but a P0000 instruction ac- 
tivates Input when the Tape Typewriter is used. 


An 10000 instruction starts the Reader, reading all 
characters into the Computer. A Conditional Stop 
code (') stops the Reader. 


Only those characters read into the Computer by the 
Tape Typewriter may be read in by the Reader. A stop 
code generates a “Start Compute” signal to the Com- 
puter and stops the tape. 


Operation of Tape Punch 
To operate the Tape Punch: 


1. Turn Computer “on” and make it ready to operate 
by warming up. 

2. Depress “Punch Power” switch once. (It lights 
up). 

3. Set Output switch to “Punch.” 

4. Depress “Tape Feed” switch and hold depressed 
long enough to obtain at least a 6 inch leader. 

5. Tape starts punching. 


6. Direct long tapes into chute, through slot in Punch 
Reader console to bin inside cabinet. 


Operation of Punch with the Computer 


A P0000 code starts the Tape Typewriter. Any one of 
the other 63 codes (01 through 63) are possible. 


A Pnn00 instruction from the computer punches 
the character represented in binary in the track portion 
of the instruction. 


At the end of each punching cycle, a “Start Compute” 
signal is generated similar to the punching operation 
of the Tape Typewriter. 


Since the punch operates approximately twice as fast 
as the Tape Typewriter, there is consequently less time 
for calculation between punch cycles. The timing using 
the punch will be further discussed in timing and 
optimizing. 


The description of the Photoelectric Reader and the 
Paper Tape Punch only describes the difference between 
programming with these units and with the Tape Type- 
writer. For more information, see Programming Input 
and Output of the Tape Typewriter. 


Timing and Optimizing 

OPTIMUM programming is the technique by which data 
and instructions are located on the drum of the com- 
puter so as to minimize non-productive searching time. 
Before describing the optimizing technique used in the 
LGP-30, it should be emphasized that the savings in 
machine time should be compared with the cost of the 
programmer’s time before deciding to optimize a pro- 
gram. 


LGP-30 Design 


An interlace pattern of sectors around the drum has 
been provided on the LGP-30. The track portion of all 
locations and addresses has no effect on optimizing ; only 
the sector portion determines whether an order is 
optimum or non-optimum. Fig. 9 shows a cross-section 
of one track on the drum, divided into 64 sectors or 
words. Since a word time is the time it takes for one 


READING HEAD 


FIGURE 9. Cross Section of Drum at any Track 


word or sector to pass under the read head and the drum 
revolves at 4000 revolutions per minute, one word time 
is 0.23 milliseconds 


Table I shows the complete sequence of sectors around 
the drum for one track. Consider the following program. 


Location Op. Address 
0000 B 1943 
0001 A 2151 
0002 C 


1943 


The instructions, B 1943, A 2151, C1943, must be 
brought into the instruction register before they can 
be executed and this can only happen when locations 
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0000 0001 0002 respectively are under the read head. 
Assume the read head is over sector 00 and is placing 
the instruction B 1943 in the instruction register. If 
this instruction, B 1943, can be executed before the 
drum turns around to sector 01 it will be an optimum 
instruction. Figure 9 shows sector 43 is between sector 
00 and sector 01 and is within the portion which is 
optimum for sector 00. The same logic applies to the 
next instruction A 2151 at location 0001. Sector 51 lies 
between sector 01 and sector 02 and lies within the 
portion that is optimum for sector 01. Both of the pre- 
ceding instructions are optimum. The next instruction 
C1943 at location 0002 will not be optimum because 
sector 43 does not lie between sector 02 and sector 03. 


TABLE | 


Sequence of sectors around the Drum 
for one Track 


00 p01 pe02 f~03 ~04 05 p06 f~00 
57 | 58 | 59 | 60 | 61 | 62 | 68 
50 | 51 | 52 | 53 | 54 | 55 | 56 
43 | 44 | 45 | 46 | 47 | 48 | 49 
36 | 37 | 38 | 39-| 40 | 41 | 42 
29 | 30 | 31 | 32 | 38 | 34 | 385 
22 | 23 | 24 | 25 | 26 | 27 | 28 
15 | 16 | 17 | 18 | 19 | 20 |. 21 
os oot tot 114 1244 1344 14 
07 


Table II shows the 16 commands the LGP-30 per- 
forms and the number of word times after the location 
of the instruction, the address of the operand must be 
in order for the instruction to be optimum. 

For example Table II shows that for a divide instruc- 
tion, if the address of the operand is 2-5 word times 
after the location, the instruction will be optimum. If 


‘the divide instruction were placed at sector 51, Table I 


will give the sector addresses of the 2 through 5 word 
times following sector 51. (37,30,23,16). 


TABLE Il 
Order 


Bring, Add, Subtract 
Hold, Clear, Store, 


No. of Word Times 


. Return Address, Extract, ator 
Print, Input, Stop | 
N multiply 2 to 8 
M multiply 2 to 6 
Divide 2 to 5 
Unconditional transfer Was ear 
and transfer 


Timing on Input 


The only timing problems that occur in Input are with 
the Tape Typewriter. If a P0000 instruction is initiated, 
an I0000 instruction must follow before any informa- 
tion reaches the read portion of the Tape Typewriter. In 
some instances, however, it may be desirable to have the 
LGP-30 send a P0000 instruction to start the tape in 
motion on the Tape Typewriter. The Tape Typewriter 
could then type a title or heading while the LGP-30 
continued to compute. 


Timing on Output 

When the Tape Typewriter is used as the Output de- 
vice of the LGP-30 it is very desirable to run the Tape 
Typewriter at top speed, approximately ten characters 
per second. This means that there are approximately 
5% drum revolutions of useful calculation between 
printing each character on the Tape Typewriter. This 


time is normally spent converting the next character to 
be printed on the Tape Typewriter. This is especially 
true if a binary to decimal conversion is required. 
After the “P” instruction supplies the typewriter 
unit with the required information to execute a print 
or a control function, control is transferred to the in- 
struction following the “P” instruction. The program- 
mer may use any instruction except another “P.” 


CONTROL PANEL 


MEMORY DRUM 


COOLING SYSTEM 


LGP-30 COMPUTER WITH FRONT COVER REMOVED 
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POWER SUPPLY 


ALPHA- 
NUMERIC 
KEYS 


Upper Lower 
Case Case 


NEM gd SCH POR RF GH CACTD DHYAT AWNMHO 


NKMSd GHndwWO HOZEA oHtay FHDOWP> AMA eS 


— Nive 


, 


+ 


| ee = ee 


CONTROLS , 


Lower Casetf 
Upper Caset 
Color Shift} 
Car Rett 

Back Spacef 
Tab: 062" 
Cond Stop (!')f 
Start Readt 
Space (.c- 
Deletey 

+Not used in Input Code 


DECIMAL 


P 0200 
P 0600 
P 1000 
P 1400 
P 1800 


P 2200 
P 2600 
P 3000 
P 3400 
P 3800 


P 5700 
P 0500 
P 5300 
P 2100 
P 3700 


P 4200 
P 4600 
P 4900 
P 1700 
P 5000 


P 5400 
P 2900 
P 2500 
P 3500 
P 3300 


P 5800 
P 1300 
P 6100 
P 4500 
P 4100 


P 3100 
P 6200 
P 3900 
P 0900 
P 0100 


P 1500 
P 1900 
P 2300 
P 2700 
P 1100 
P 0700 


P 0400 
P 0800 
P 1200 
P 1600 
P 2000 
P 2400 
P 3200 
P 0000 
P 0300 - 
P 6300 


APPENDIX A 
TABLE | 


COMPUTER CODES ON TAPE TYPEWRITER KEYBOARD 


“Pp” INSTRUCTION 
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OUTPUT CODE 


6-BIT BINARY 


(TRACK PORTION) 


123456 


000010 
000110 
001010 
001110 
010010 


010110 
011010 
011110 
100010 
100110 


111001 
000101 
110101 
010101 
100101 


101010 
101110 
110001 
010001 
110010 


110110 
011101 
011001 
100011 
100001 


111010 
001101 
111101 
101101 
101001 


011111 
111110 
100111 
001001 
000001 


001111 
010011 
010111 
011011 
001011 
000111 


» 000100 
: 001000 
001100 
: 010000 
010100 
011000 
1100000 
000000 
000011 
111111 


INPUT CODE 
4-BIT, 6-BIT 


BINARY 
123456 


2 ner 
0001 
0010 

~0011 
0100 


+0101 
«0110 
0111 
1000 
- 1001 


1110 
0001 
1101 
- 0101 
-- 1001 


*1010. 


1011 
- 1100 
0100 
- ee 


1101 
0111 
: 0110 
- 1000 
1000 


1110 
- 0011 
: 1111 
1014 
1010 
« OL 


“1111 J. 


1001 
0010 
+ 0000 


0011 
‘ 0100 
0101 
0110 
‘ 0010 


“ 0001 |" 


Tab 0000 


Space 0000 
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10° 


10 
10 
10 


10 
10 
10 


10° 


10 


01: 


01 


01. 
‘01 


01 


10 
10 
Ol 
01 
10 


10 


01 
01 
11 


ol 


00 
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APPENDIX B 


SCALING 


The operation of scaling is performed by the pro- 
grammer to eliminate overflowing the accumulator or 
loss of precision. 

Before programming a problem on a computer, a 
technique for scaling the data must be employed. Vari- 
ous techniques may be used depending on the number 
system. In the decimal system 10 is the basic number. 
However, the LGP-30 is designed about the binary 
system, using a base of 2. In scaling data, the binary 
point, “q’’, represents the number of places from the 
extreme left of the data word, where the radix point is 
_ located. (The radix point indicates the separation be- 
tween the integral and fractional portions of a data 
word.) Given a data word, its “q’” is determined from 
the table of Powers of Two, Table I, for example number 
200 must be held at least a “q’’ of 8. In representing a 
word of 30 bits, excluding the sign bit to the left, See 
a A below, qo is considered to be at the extreme 
eft. 


Example: 


Sllfelo}fofofol PT TP 
q=8 


FIGURE A 


The rules for scaling in arithmetic operations of the 
LGP-30 are the same as those in other computing de- 
vices. To add or subtract two numbers, they must be 
held at the same “q’s.” (In a desk calculator, this is 
equivalent to lining up the decimal points.) The result 
of such addition or subtraction — is a number at the 
same “q.” 


In multiplication, the ” of the two numbers need not 
be the same. The ane of two such numbers is a 
number at q,, = 4; + G2 where q, is the binary point of 
the multiplier and q. is the binary point of the multipli- 


“Q’s 


SIGN 


Flojefefofofol | | Ly 
q=6 


cand. In division, the quotient of two numbers has a 
Qa = 4142 where q, is the binary point of the divident, 
Qo is the binary point of the divisor. In multiplication, 
q’s are added, in division, the q’s are subtracted. 


Since the purpose of scaling is to shift data into such 
favorable locations to eliminate loss of precision, it is 
important to determine how shifts are made without 
altering the value of the data. Any number multiplied 
by the integer, 1, results in the same number. But any 
number multiplied by the integer 1 at q=n shifts the 
number in the accumulator by n places to the right. This 
will place the number in the required location. For ex- 
ample, to add 5 at aq=10 to 10 ata q=12, the 5 at 
q = 10 must be multiplied by 1 at q = 2 to obtain 5 at 12, 
or shift 5 to location q = 12 in accumulator. Then, we 
can add the result in the accumulator. Thus, we shift 
the contents of the accumulator to the right so that the 
radix point is located at the required q = 12. 


It is sometimes required to shift left to scale a num- 
ber to a q smaller than that given. In this case, divide 
the number to be scaled by the integer, 1 at q =n, and 
thus shift it in the accumulator by n places to the left. 
For example, 7 at q=4, divided by 1 at q= 2 equals 
7 at q= 2. However, it must be noted that 7 cannot be 
located at a q = 2 since the last remaining digit to the 
left will overflow and stop the computer. A mental check 
is necessary to determine the “‘fit” of the quotient in the 
accumulator before dividing. In this case, it is possible 
only to divide 7 at q=4, by 1 at q=1 to obtain 7 at 
q = 8, which will “fit” into the accumulator. 


Another method of shifting left utilizes the ‘N” 
multiply instruction. This instruction retains the least 
significant half of the product in the accumulator. To 
shift a number left n places, ‘““N’” multiply the number 
by 1 at q=(81-n). For example, given 7 at q= 6, we 
want 7 at q= 4, therefore, shift left by 2 places. To do 
this, “N multiply” 7 at q=6, by 1 at q=(81-2) to 
obtain 7 at q = 35. This is equivalent to 7 at q = 4 as can 
be illustrated below. 


From the following illustration, we note that the 31st 
bit of the total product is in the sign bit of the accumu- 
lator. 


}<—_—_—-—- ACCUMULATOR 
“\ 


ee ACCRNGOOCI am 


q=30 
q=l 


q=35 
q=4 q=3 


MOST eponuet 
HALF OF PRODUCT LEAST SIGNIFICANT 
RETAINED WITH HALF OF PRODUCT >| 


"M" MULTIPLY 
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RETAINED WITH 
N" MULTIPLY 


TABLE | 


POWERS OF TWO 


Positive Power—2N N Negative Power—2-N 
Power 
1 0 61.0 
2 1 0.5 
4 2 0.25 
8 3 0.125 
16 4 0.062 5 
82 5 0.0381 25 
64 6 0.015 625 
128 7 0.007 812 5 
256 8 0.003 906 25 
512 9 0.001 953 125 


1 024 10 0.000 976 562 5 

2 048 11 0.000 488 281 25 

4 096 12 0.000 244 140 625 . 
8 192 13 0.000 122 070 312 5 
16 384 14 0.000 061 035 156 25 


32 768 15 0.000 030 517 578 125 

65 536 16 0.000 015 258 789 062 5 
131 072 17 0.000 007 629 394 531 25 
262 144 18 0.000 003 814 697 265 625 
524 288 19 0.000 001 907 348 632 812 5 


1 048 576. 20 0.000 000 953 674 316 406 25 

2 097 152 21 0.000 000 476 837 158 203 125 

4 194 304 22 0.000 000 238 418 579 101 562 5 

8 888 608 23 0.000 000 119 209 289 550 781 25 
16 777 216 24 0.000 000 059 604 644 775 390 625 


838 554 4382 25 0.000 000 029 802 322 387 695 312 5 

67 108 864 26 0.000 000 014 901 161 193 847 656 25 

184 217 728 27 0.000 000 007 450 580 596 923 828 125 
268 485 456 28 0.000 000 003 725 290 298 461 914 062 5 © 
586 870 912 29 0.000 000 O01 862 645 149 230 957 031 25 


0.000 000 000 931 322 574 615 478 515 625 
2 147 483 648 31 0.000 000 000 465 661 287 307 739 257 812 5 


_ 
oO 
J 
ie) 
J 
cS 
= 
io) 
i) 
paw 
ise) 
oO 
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OPTIMUM OPERANDS 


For all orders except U, T, M,.N, and D, 2.25 ms. (7 word 
times) is required if the operand sector is optimum; 19.25 ms. (77 word 
For N, M, and D, the times are 19. 25 and 36. 25 ms. 
(77 and 145 word times), respectively. Execution times for U and T are 
given in the table Transfer Times". a | i 


times) otherwise. 


Order | Any but | 
Loc. U or T Any 
00 4 
Ol 51. 44 137 30 
02 52 45 | 38 31 
03 53 46139 32 
04 54 47140 33 
05 55 48 | 41 34 
06 56 49 142 35 

- 07 57 50/43 36. 
08 58 51 |44 37 
09 59 52145 38 

10 | 60 53 |46 39 
ll 61 54]47 40 
2 62 55,48 41 
13 63 56449 42 
14 00 57]50 43 
15 | O1 58 | 51 44 
16 02 59 |52 45 
17 03 60|53 46 
18 04 614154 47 
19° 05 62{155 48 
20 06 63156 49 
21 07 00!157 50 
22 08 01158 51 
23 09 02159 52 
24 10 03}60 53 
25 11 04161 54 
26 12 05 {62 55 

eer 13. 06 | 63 56 

28 14. 07100 57 
29 i5 08 j]01 58 
30 16 09 |02 59 
31 17 10/03 604 


Not 
D D,M 


Only || Order 
Loc, 


1Z 


13 
“14 


15 
16 
17 
18 


19 


-20 


21 
ZL 
Zo 
24 
25 


26 


27 
28 
29 
30 


31 
32 


Pee) 


34 


35 
36 
37 


38 
39 


40 


41 | 
42 


55 

56 
By 
58 
59 
60. 
61 
62 
663 
00 
Ol 


02 
03 
04 
05 


06 
07 
08 
09 


10 
1] 
ie 
13 


4 
15 
16 
17 
18 
19 
20 
21. | 


62 
06 63 
00 


21 14 
“22 


25 
26 


29° 
30 


TRANSFER TIMES 


A"U" or a '"T" order in sector A which transfers to sector B 
takes t word times. a 


B-A B-A a: B-A... B-A t 


0 
: -63 9 33 3] Al 
2 762 18 34. - 30 50 
3 -61 27 35 ~29 59 
4 -60 36 36 28 4 
5 ~59 45 37 27 13 
6 58 54 38 26 32 
f al 63 39 ~25 ai 
8 -56 8 40 aoa 40 
9 ~55 17 4] eo} Ag 
10 ~54 26 A2 22 5B 
: ae oe 43 -21 67 
12 252 44 Ad 30 es 
am at 53 45 219 21 
a ee 46 -18 30 
S an 7 AT 17 39 
16 2a8 16 Ag a6 ke 
a Bia. 25 49g 15 57 
- oe a 50° -14 66 
ae ae = 51 -13 11 
- nee oe 52 12 20 
. oe e 53 -11 29 
ae eee 6 54 -10 38 
a ges oe 55 - 9 AT 
f -40 24 56 a 56 
25 ~39 33 57 _ 7 65 
ee 208 42 58 i 
- — 2 59 - 5 19 
28 ~ 36 60 60 _4 23 
29 - 35 5 61 48 on 
- ie oe 62 a2 46 
? = ee 63 1 55 


- “ Baa ' a , al ae 
i ; e on - e — ons 
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